NEW FEATURES OF LNBUG 5,0 

August 23, 1979 

LNBUG 5 is an updated version of all previous LNBUG monitors, 

obviously expected to be as complete as ever needed but un¬ 
doubtedly due to change! 

1. Cool Reset - Resets everything except patches, break¬ 
points^ and macro commands. Type "C" upon reset. 

2. Macro Command Files - Save up to eight command lines for 
later use without retyping addresses, data, etc. (J com¬ 
mand) 

3. Loading and Writing to tape now has a switch (") to allow 
selection of either terminal port or auxiliary port. 

4. Uploading and Downloading and Other PDP11 Communications - 
LNBUG 5 contains a simple method to communicate with a time- 
share system including uploading from LNBUG and downloading 
to LNBUG. For previous LNBUG 3 users, /\ D replaces AS for 
return to LNBUG. 

5. Read-Modify Sequence - When listing a line at a time using 
the V" immediate command, the beginning of the last line 
is opened for modification rather than the address that the 
whole listing began. 

6. Zero Page RAM - To allow development of Stella (Video Com¬ 
puter System) programs, the required LNBUG zero page RAM 
has been moved from 00-03 to FC-FF. (Stella has no RAM at 
the bottom of zero page). This should make little differ¬ 
ence in user program operation as LNBUG retains a pseudo 
zero page for the user. See "CAUTIONS" for further details. 

7. Carriage Return Delay - Instead of delaying a clock-dependent 
time for hard copy, the delay program simply outputs 10 null 
characters instead - (Baud rate dependent). 

8. Interrupts and Single Stepping - A correction has been made 
to allow single stepping through an interrupt program with¬ 
out fouling up the interrupt status. However, due to in¬ 
herent conflictions of hardware and the variable complexity 
of interrupt structures versus a debug monitor (real time 
versus stop time) , problems may still arise. It is recom¬ 
mended that a trace analyzer be used for real time operations. 

9. Colleen ROM O.S. - See section at end of manual for update 

on interrupt vector handling. Replace Address Map "ROM" with 
Coleen Address Map "PROM". 

10. RAM Relocation - RAM has been moved to C000-C2FF . 

Single Step - With Colleen ROM O.S. you must use the new 
address PROM to prevent single* stepping -f rom D3Q0 — F - F - F - F - 

AT E.7XX 
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OTHER DEVEL OPMENT SYSTEM CHANGES AND ADDITIONS 
August 23, 1979 -- 


1* Mew baud rate switches to be mounted on front panels. 

2. Colleen processor card with Colleen chips. 

3. Colleen address map and RAM requirements have been changed. 

4. Changes to gradually be implemented on the TMI cards add 
higher quality connectors, Aux. port polarity switch, separ¬ 
ate connector to allow the use of a terminal for LNBUG only 
and one for the trace memory. 

5. Trace memory - See trace memory manual. 

6. Updated trace memory manual and LNBUG 5 manual 

For answers to questions, please contact Larry Nicholson, Cyan 

Engineering, Grass Valley (916) 273-6194. 
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LNBUG 6500 DEVELOPMENT MONITOR 


INTRODUCTION : The MCS6500 Development Monitor is a 

comprehensive debug package including complete list 
•and modify commands, mini-assembler/disassembler, disc 
and tape communications, stepping, trace, and breakpoint 
capabilities, and other useful memory manipulation com¬ 
mands. The program is designed to run on an S-100 type 
computer utilizing an Atari trace memory interface board 
with a video or hard copy terminal. 

To run the monitor, the system must be configured 
as follows: 

1 - Atari GVA-2503 CPU card (or Coleen wire wrap CPU) 

1 - Dynabyte 16K RAM card 

1 - Cromemco 16K ROM card ' 

1 - Atari GVA-2504 Trace Memory Interface Card 

Make sure to set switches as specified on sheet labeled 
"DEVELOPMENT SYSTEM SWITCHES." A copy of this is in¬ 
cluded at the back of this manual. 

With the BOOTSTRAP switch on, the monitor will 
be entered upon reset, starting at location 6000 (GVA- 
2503 only). 

If reset is desired to clear vectors and reset all 
monitor cells, a carriage return should be the first 
character entered. A "Cool" Reset will clear everything 
except patches and breakpoints. (Type "C".) A "W" 
causes a warm reset and clears nothing. The monitor will echo 

"NOW ENTERING LNBUG #X" 

to indicate the entry to the monitor and the version 
being used. 

After a "Cold" reset, the user must select the 
control set for the terminal being used: 

Type "D" <CR> for a digilog terminal. 

Type "H" <CR> for a hard copy terminal. 

For Lear Siegler, type nothing. 

The monitor is now ready for operation. 

Note: See Appendix on Interrupt Handling for Colleen ROM O.S. 
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BASIC COMMAND FORMAT : 

Commands to the monitor are entered in a line 
at a time in the deferred mode or with a single key¬ 
stroke in the immediate mode. 

The command and the optional suffix are always 
entered in after necessary address and data entries. 

Examples: 

Format Example 


Command Suffix 
Adr Command Suffix 
Adrl.Adr2 Command Suffix 
Adrl.Adr2, Data Command 
Adrl.Adr2, Adr3 Command 


DX 

1000/Q 
1000.1100/Q 
1000.1100,00# 
1000.1100,1003m 


"Adrl.Adr2" indicates start and stop addresses. 
"Adr3" indicates destination address, "Suffix" is 
always optional. "Deferred" commands are line ori¬ 
ented and all key entries are stored in a buffer un¬ 
til <CR> is hit. The buffer can be modified prior 
to execution using various key buffer operators. 


COMMAND DESCRIPTIONS : 

The following descriptions are organized into 
the following groups: 


List and Modify Memory 

Macro Memory Operators (Move, Verify, etc.) 

Patching Command 

Program Loading and Saving 

Key Buffer Operators 

Functions for Running Programs 

Suffixes 

Relocation Register 
Terminal Control 
PDP-11 Communications 

In the following descriptions, Mode "D" is the 
deferred mode and "I" is the immediate mode. (See 
descriptions above.) All values are in hexidecimal. 


Reset Modes 

CR - Cold reset clears all breakpoints, patches, 
vectors, step-mode, hardware, etc. 

C - Cool reset clears everything except break¬ 
points, patches, "K" macros, and "J" macros. 
W - Warm reset clears hardware only. 
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LIST AND MODIFY: 


Command 

R 


/ 


Mode 


Description 

Display user CPU registers . 

EX: User types- R 

Monitor prints: 

PC=2000 P=00 A=01 X=FF Y=FF S=EA 


D List memory from start to stop address. Or, 

if start address only is specified, all locations 
up to the next address increment of sixteen will 
be listed. 

EX: User types- 1000.1008/ (echoed) 

Monitor prints after return: 

0123456789ABCDEF 
1000 = AA 00 A9 11 01 FF 21 BC C9 

EX2: User types- 100A/ (echoed) 

Monitor prints after return: 

01234567 

100A = 

EX3: User types- 2000.2006/Q 

Monitor prints after return: 


2000 

LDA 

I , 0FF 

2002 

STA 

Z,10 

2004 

DEX 


2005 

BNE 

2028 


I When no address is specified, list the next sixteen 

locations starting from the last list address plus one. 
Allows convenient continuous listing. 

EX: User types- / (not echoed) 

Monitor prints: 

1010 = AA 99 24 32 7D A9 C0 0D (etc.) 


A B C D E F 
B9 01 21 C9 00 D0 


(echoed) 



LIST AND MODIFY (continued) 


Command 
SHFT / 


Mode Description 

I List one location . 

EX: 1000/ (echoed) 

Monitor reprints line on shift /: 

1000 = A9 

A repeat of just the shift / prints: 

1000 = A9 again 

(This is useful for reading PIA ports) 

D Modify memory . Opens memory for modification 

starting at specified address. Memory is not 
actually modified until carriage return is hit 
or until address passes over an increment of 
sixteen. (Automatic carriage return for con¬ 
tinuous entry.) All key buffer operators can be 
used. (Rub, escape, etc.) 

EXl: User types- 1000: (echoed) 

Monitor prints: 

0123456789ABCDEF 

1000 = 

The cursor is then positioned under "0" waiting 
for a user entry. 

EX2: User types- 1000: (echoed) 

Monitor prints: 

1000:Q 

The monitor is now waiting for the user to enter 
in mnemonics. 
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LIST AND MODIFY (continued) 


Command 


SHFT: 


Mode Description 

I Modify memory starting at start of prior listing. 

Or , modify user CPU registers if "R" command pre¬ 
ceded command. All other characteristics are 

identical to in the deferred mode. 

EX: User types- 1000/ 

Monitor prints locations 1000-100F as shown above. 
User then types : (not echoed) 

Monitor prints: 

1000 : 

The monitor is now waiting for user entry. Note: 

If listing was made using the immediate mode 
the beginning of the current line will be opened 
for modification. 

I Modify one location . Immediate modification of 
one location. 

EX: User types- SHFT: 

Monitor prints: 

1000 : 

Only this one location will be modified and 
address location pointer is not incremented. 

D Macro Listing Command . A macro listing command used 
during trace or under user control. Up to six single 
locations or lists (of any length) can be specified 
and then listed either during breakpoint/step opera¬ 
tion or when "K <CR,> " is specified. To set these, 
specify: Adrl.Adr2 - List, Adrl - Single location. 

Separate with commas, and end line with "K<CR> ." 

Any number of entries (up to six) are allowable and 
can be in any order. The "X" suffix clears the "K" 
directory. 

EX: User types- 00.0F ,4094,4021K 

When a breakpoint occurs in a user program, or if 
the user types in "K <CR> ", the monitor will print: 

123456789ABCDEF 
0000 = AA 10 00 00 FF 00 10 01 11 AC C9 F0 D0 00 00 
4094 = 21 
4021 = A2 

Note that if trace mode is set, the listing will be 
made after every breakpoint, whereas, if the trace 
mode is not set, the listing will be made after 
passing through the breakpoints "N" times as set by 
the "N" command. 
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MACRO MEMORY OPERATORS 


Command 

M 


Mode Description 

D Move memory from start address to stop address to 
destination address. Accounts for direction of 
move to prevent memory destruction in overlapping 
moves. 

EX: User types- 153T0J2T. 10FF, 100T3M 

Monitor then moves block up three bytes. 


D Program 2708 EPROM's using Byte-Saver board. 

Specify source start and stop addresses and des¬ 
tination address (Byte-Saver address). Any 
number of bytes can be programmed at a time with¬ 
out timing problems as the program always main¬ 
tains at least a !l IK Duty Cycle" to prevent 
damage to the PROM. 

EX: User types- 1000. 13FF,8000! 

Programs RAM area 1000 to 13FF to the PROM 
located at 8000. 

Monitor then prints: 

PROM AREA O.K. 

IS PROGRAMMER UNPROTECTED & READY? 

The user then types either "Y" for yes or "N" 
for no. Yes starts the programmer, no returns 
control to the monitor. 


D Compare memory . Compare one block of memory with 
another. Specify start and stop addresses of one 
block and start address of block to be checked (Adr3) 

For example, see move instruction and verify in¬ 
struction . 


D Verify proper memory operation by writing "55" and 

"AA" to locations, while saving current contents for 
non-destructive checking. Specify start and stop 
addresses. 

EX: User types- 2000.3000V 

Monitor prints : 

First error 2400 
Total errors = 1024 
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MACRO MEMORY OPERATORS (continued) 


Command Mode^ Description 

# D Fill memory with specified data byte , starting 

at Adrl and ending at Adr2. 

EX: 1000. 1FFF ,00# will set locations 1000 to 

1FFF with "00." 


Z D Delete all memory . 

J D or I Macro Command Files . Up to eight (0-7) separate 

lines of commands can be stored and later recalled 
without having to re-enter all addresses, data, 
etc. This is useful for periodically listing a 
section of memory, setting breakpoints, etc. 

Setup Macro Command: 

EX: 1000.10FF/3J - Sets macro command file 

#3 to 1000.10FF/. 

Execute Macro Command: 

EX1: 3J - Execute command set up in above 

example. 

EX2: J - Immediate command to execute contents 

in file #0. 

List Macro Command: 

EX: 0/J - List zero macro command file. 


Delete Macro Command: 

EX: 7JX - Deletes macro command file #7. 
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PATCHING COMMAND 


Command 

I 


Mode Description 

D , Insert patch in program. Allows user to 

specify an address in the program under develop¬ 
ment and insert instructions at this address 
without affecting the rest of the program. The 
monitor actually places the patched code in a 
"Patch Area" and inserts a "BRK" at the user 
program address upon starting the program. 

Utilizing a "Patch Directory," the monitor is 
able to vector the user program to the proper 
patch in the patch area upon encountering a 
"BRK." The patch has already been constructed 
automatically to jump back to the user program. 

EX: 

User Program 
1000 LDA 1,00 
1002 STA ZX,03 

1004 DEX 

1005 BNE 1000 

Insert "DEY" at 1002. 

Patch area: 

40A6 DEY 

40A7 STA ZX,03 Added automatically 
40A9 JMP 1004 by patch program 

Or, insert "BPL 1010" at 1005 
Patch area: 

40C6 BMI 40CB 

40C8 JMP 1010 This structure automatically 
40CB BEQ 40D0 constructed by patch program 
40CD JMP 1000 
40D0 JMP 1007 

Note that upon return to monitor, all "BRK" 
instructions are replaced with the original in¬ 
struction making the patch transparent upon 
listing. 

Eight blocks of 32 bytes each are maintained 
in the patch area. Thus, a maximum of eight 
patches can be made. If a patch consumes more 
than 32 bytes, it will automatically link it¬ 
self to the next patch area block provided the 
block is free. 

A patch is specified by entering in the address, 
the desired patch number (optional - automatically 
finds available patch), the "I" command, and a 
carriage return. The desired instructions are 
then entered in mnemonics a line at a time. Two 
carriage returns in a row will terminate the patch. 
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PATCHING COMMAND (continued) 


Command Mode 


Description 


The patch is effectively placed just prior 
to the address specified. Note that this 
type of patch consumes an average of 100- 
200 processor cycles and should not be used 
in time critical operations. 


IX 


D "AdrIX" deletes that patch. 

"0,Patch#IX" also deletes one patch. 


EX: 0A IX deletes patch #4 

"IX" deletes all patches 

LISTING & SAVING PATCHES 

"I" lists patch directory for reference use. 


To save patches and breakpoints, write loca¬ 
tions C064-C0A5 to the disc or tape. Note 
that this will also store the user's zero 
page locations 0FC-0FF, the trace mode, re¬ 
location register, and step counter. DO NOT 
RECORD this section while in step mode. Al¬ 
ways load this section before setting step 
mode. 


PATCH & BRKPNT WARNING 


If a location that is a patch is modified, 
that patch will be deleted from the patch 
directory. But, if the location is changed 
to a 00, the old patch code will be replaced 
and the patch maintained, even though the 
program will not run correctly. Care should 
be taken when modifying patched code. Ref¬ 
erences to patches here also apply to break¬ 
points . 
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PROGRAM LOADING/SAVING 


Command Mode Description 

L D Loads data from terminal or auxiliary port 

in the standard MOS Technology LOAD format. 
Returns control to monitor upon receipt of 
an ASCII DC3 (Control X-Off). No address 
is specified. Note that tapes made with 
this monitor contain the "L," <CR> and DC3, 
so loading is done by simply turning on the 
tape. Echoes on terminal if trace mode is set. 


W D Write hex to terminal or to auxiliary port 

in standard MOS Technology format. Specify 
start and stop addresses in the usual fashion. 
Note that an "L," <CR> and DC3 are transmit¬ 
ted at the proper times to allow simple re¬ 
loading . 

" Suffix Select auxiliary port load or write . Add as 

a standard suffix to the L or W commands. 

See "PDP-11 Communications" for uploading 
and downloading from PDP-11. 


KEY BUFFER OPERATORS 


RUB 


Line Feed 


Space 


Backspace 
(Control H) 

Escape 

CR 


I Delete Last Entry . Rubout - erase last 
entry. On Lear Siegler, underscore is 
equivalent; i.e., shift is not required. 

I Non-Destructive Advance . Advance one ad¬ 
dress or one instruction (in mnemonics mode) 
if first entry of line, or one character in 
any other mode. Does not affect contents 
of buffer or memory. This should be used 
only to skip a previous entry. Space should 
be used initially if skips are desired. 

I Delete Current Entry and Advance . Erase 

previous key entry and advance one address 
if modifying memory in hex mode. Otherwise, 
print non-functioning space character. 

I Back Up One Address . 


I Delete and Escape Current Line . 

I Execuce Current Line. 
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FUNCTIONS FOR RUNNING PROGRAMS 


Command Mode Description 

G D Go From Start of Program . "GO" starting 

either at specified address or at address 
specified in previous GO command if no ad¬ 
dress is specified, (for restarting program). 

EX: First Pass: 1000G 

Starts program at 1000. Thereafter, typing 
only a "G <CR)> " will start program at 1000. 


P I Proceed From Current Program Address. (Pro¬ 

ceed from BREAKPOINT, SINGLE STEP, Control C, etc.) 


V 


S 


T 


N 


B 


D Set single step mode (Use SX to reset to 

continuous mode.) NOTE: If Coleen ROM O.S. is 
used, LNBUG5 address prom must be used also, 
see Appendix on Interrupt Handling. 

D Set trace mode (use TX to reset). Lists 

breakpoint #, CPU registers, next instruc¬ 
tions, and any memory locations as specified 
in K command upon breakpoints or single step. 
Also used to specify an echo upon loading 
programs via the terminal. (See "L" command.) 


D Set Number of Steps or Breakpoints . Set 

number of times through breakpoints or sin¬ 
gle step before tracing and returning to 
monitor. Specify any hex number up to "FF." 
Note that "0N" will run continuously. 
Specifying just N with no number defaults 
to 01. 

EX: "10N <CRj> 11 will cause 16 breakpoints 

or steps to run before stopping. 

D Set Breakpoints, List Breakpoints . Specify 
as: ADR,#B where # is the breakpoint number 

(1-8). Specifying 0,#BX will delete that 
breakpoint. BX deletes all breakpoints. 

"B" only lists breakpoint directory. 

EX: User types- 1004,3B 


Run Program (trace mode set, N=02). 

Monitor prints: 

#3 PC = 1004 A=01 X=FF Y=00 S=FA BNE 1000 
#3 PC = 1004 A=01 Y=FE Y=00 S=FA BNE 1000 

CAUTION: See warning in "I" instruction about 

modifying location specified as a breakpoint or 
patch. 
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FUNCTIONS FOR RUNNING PROGRAMS (continued) 


Control C I Reenter Monitor From User Program . 

Returns control to monitor while running 
a user's program. Uses IRQ interrupt pro¬ 
cessing. Will not function if vectors are 
changed or interrupt flag is set. 

SUFFIXES 

Q Set Mnemonics Mode . Used to cause monitor 

to speak and listen in mnemonics rather than 
hexidecimal. Applies only to "/" and 
commands. This is a single pass assembler 
and maintains no symbol handling capabilities. 
"I" command assumes mnemonic mode. For ex¬ 
amples see "/" and commands. 


X Delete suffix - used to reset trace and single 

step and delete breakpoints, patches, terminal 
modes (H & D), and K listing. Note that 
using only a command and the X suffix deletes 
all breakpoints, patches, or K listings. 


RELOCATION REGISTER 

Set relocation register address. For use 
with relocatable program sections (CSECT). 


Add Relocation Register to Address . Used 
as a suffix to any address that is a relative 
address and must have the relocation register 
added to it. 

EX: 

1. ) 1000Y <CR> sets relocation register at 1000. 

2. ) 01A2Y/<CR> lists locations 11A2 thru 11AF 

on screen. 


TERMINAL CONTROL 

D D Set Digilog Mode . Sets monitor to use Digilog 

control set. 

H D Set Hard Copy Mode . Sets monitor to use hard 

copy control set as well as delaying carriage 
returns and not double printing for such op¬ 
erations as rubout. 

Upon cold reset, the monitor assumes the Lear 
Siegler video terminal control set. Use "X" 
suffix to reset either hard copy or Digilog modes. 


Y D 


Y Suffix 
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PDP-11 COMMUNICATIONS 


$ 


* D 

U 


D 


I 

D 


Enter bidirectional communications between 
terminal and PDP-11 host computer. 

Note: Since no buffering is used, the LNBUG 

terminal should always run faster than the 
computer baud rate. Since trace memories 
require 19,200 baud, this should not be a 
problem. 

Return to LNBUG monitor from "$." (All 
other characters are passed on to the PDP-11.) 

Upload from LNBUG to PDP-11 . Specify start 
address and stop address in standard format. 

User will now be talking directly to the PDP-11. 

EX : 1000. 12FFU <CR> <CR> (user enters) 

.TSX Ver 3 (PDP-11 echoes) 

12-Mar-79 


.UPLOAD filnam.ext (User enters) 

$ <CR> <CR> 

*Now entering LNBUG #4 (LNBUG re-entered) 
Download to LNBUG from PDP-11. 


EX : T <CR> 

$ <CR> 

.TSX Ver 3 
12-Mar-79 

.DLOAD filnam.ext 

; 182000 - -'—{Data) 

Now entering LNBUG #4 


(User enters) 

(User enters) 

(PDP-11 echoes) 

(User enters) 
(PDP-11 sends data) 
(Back to LNBUG) 


Note: "Upload" allows only 4.5 KB (approx.) 

of loading per file unless upload command 
file is modified (TSX). 
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APPENDIX 


ASSEMBLER/DISASSEMBLER FORMAT 


The format for the assembler is identical to that of 
the Atari MAC65 format (excluding symbols). This assembler 
is a 6 500 adaptation of the RT-11 MACRO, written by Dave 
Sheppard of Coin-Op Engineering. 

EX: 


Mnemonic- 


LDA NY,04 

I \\ 

Address\ Operand 

Mode Comma Separator 


Note that the development assembler does not recognize 
symbols and all operands must be in hexidecimal. The "Y" 
relocation suffix can always be specified. Branch in¬ 
struction operands are specified as the absolute (or re¬ 
locatable "Y") address. The offset address is then cal¬ 
culated from this address. 


If an error is detected, the assembler prints the error 
message and then returns the cursor to the beginning of the 
line for re-entry of that line. 

To terminate assembly, hit carriage return without en¬ 
tering any other keys (blank line). 

Address Mode Specification - 


(none) 

— 

Relative, Implied, 
Absolute (Default). 

I 

- 

Immediate 

A 

- 

Absolute 

Z 

- 

Zero Page 

NX 

- 

(Indirect,X) 

NY 

- 

(Indirect),Y 

ZX 

- 

Zero Page,X 

AX 

- 

Absolute,X 

AY 

- 

Absolute,Y 

N 

- 

Indirect 

ZY 

- 

Zero Page,Y 


Accumulator, 


or 


- A1 




NEW COLLEEN ADDRESS MAP 
August 23, 1979 

RAM 

0- 5FFF 

ROM 

6000-7FFF 

RAM 

8000-Bfff 

LNBUG RAM 

C000-C7FF 

PROM SOCKET 

C800-CFFF 

D000 

CTIA 

D100 

VACANT-ON CARD 

D200 

POKEY 

D300 

PIA 

D400 

ANTIC 

D500 

EXTERNAL 

D600 

S100 10 

D700 

ACIA'S 

D800-Dfff 

ON BOARD RAM 

E000-FFFF 

RAM/O.S. ROM 

216 
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MONITOR SUBROUTINES 


The following subroutines can be called by a user's program 
for terminal communications and other useful functions. To 
use, assemble the file MONSBR.MAC with the user program. It 
is a set of equates that call the routines. (File on G.V. 
System Disc). 

The following describes the routines: 


GETKEY=6000 

GETHX=6003 

PRINT=6006 

HXPRNT=6009 

SP=600C 

BAKSP=600F 

RETURN=6012 

LINEFD=6015 

HTAB=6018 

KEYHND=601B 


LSTHEX=601E 


LSTHED=6021 
LSTQ=602 4 

DISASM=602 7 

WARMST=602A 

TDELAY=602D 

HEXX=6030 

KEYSTATUS= 

C0B2 


BUFF=C03E 
USIRQL=C2B8 
USIRQH =C 2 B 9 


Get character from terminal 

Get two ASCII characters & compact to hex byte 

Print ASCII character on terminal 

Print hex byte in two ASCII characters 

Print space 

Print backspace 

Carriage return line feed w/delay for hard copy 
Linefeed only 

Tabulate non-destructively N spaces 
Master keyboard handler has rubout, advance, 
back up, etc. Characters are put in "buff" 
starting at location C05D and working backwards 
to C03E. The X register is returned with a 
pointer where buff+x points at the last entry. 

To retrieve additional characters, increment X 
until X=1F. A maximum of 32 characters can be 
entered into buffer. The 33rd entry will cause 
a return with the zero flag not set. 

List hex from start to stop addresses. 

Set the following locations: 

OFE, C006 - Start ADL 

OFF, C007 - Start ADH 

C002 - Stop ADL 

C003 - Stop ADH 

Note that pseudo locations are printed for 00-03 
Same as LSTHEX except adds header to printout 
List mnemonics from start to stop. Set para¬ 
meters as shown above. 

Print current instruction in mnemonics. Specify 
only start address parameters above. 

Monitor re-entry point 

Carriage return delay (10 null characters) 
Converts ASCII character to LSD hex 

6850 status save cell for processing user key¬ 
board interrupts (6850 status register is not 
valid if a key has caused an IRQ int). 

Key buffer 

User IRQ vector under Colleen ROM O.S. 


HIRQL=FFF8 User IRQ vector without Colleen ROM O.S. 
HIRQH=FFF9 
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DEVELOPMENT SYSTEM SWITCHES 


z-2 BOX - RESET: POC to complete system. 

TMI - TERM. Set baud to monitor terminal. Set one 

(1) switch only for desired rate. 

AUX Set baud rate for 2nd serial channel. 

A15-8 Address decode of 2 serial ch a nne ls. _ 

COLEEN Set for D7 negative logic-A15 A14 A13 A12 

A10 A9 A8 


POLARITY 

PROCESSOR (GVA-2503 
RESET 

1 MHZ 

2 MHZ 
EXT CLK 

JOLT/PROM 

BOOTSTRAP 

BUS DISC. 

W.D. DISABLE 

COLEEN PROC. 

TRACE MEMORY 


Up for Aux port connection to PDP-11 (Term.) 
Down for Aux port connection to term. (Comp.) 
Only) 

Local reset to processor and associated TMI 
Selects processor clock 

Use only one switch at a time. (ON=SELECT) 

Selects one of two address decode maps, 

(ON=JOLT, OFF=LNBUG) 

Enables power-on remapping of 7FFF to FFFF. 
(Force A15 on reset if switch is on) 

Enables processor to system buss vs. stand 
alone (ON=normal, OFF=disconnect). 

Kills a .1 s hardware watchdog reset. 

(ON=DISABLE WATCHDOG) _ _ J 

W.D., BUS DISC, BOOTSTRAP, JLT, EXT. CLK .,2,1 
W.D., BUS DISC, BOOTSTRAP, JLT, EXT. CLK.,2,1 


16K SYSTEM: 


DYNABYTE RAM 

BANK SELECT 
WRT PROT 
BANK 3&4 
BANK 1&2 


1-8 open: 9 on 
1-5 open 
Set to CX & FX 
Set to 00-1F 


32K SYSTEM: 


DYNABYTE 

- Set 

as above 

, except 

BANK 

1&2 

Set 

to FX & 

CX 

BANK 

3 &4 

Set 

as desired - See 

IMS 

RAM 

32K 

systems 

only 



J2 


uWr 



Mem 

addr 

0 (0 



J1 


on, sp 



J 4 


8,4,2,1 



J5 


2 , sp 



Addr: 7-6 

3 




5-4 

3 




3-2 

3 




1-0 

none 
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DEVELOPMENT SYSTEM SWITCHES (continued) 


DRC PROM CARD 


D9-D16 n.c. 

D1-D8 diodes 

WAIT 1-14 jumpered 

Select 2-7,3-6 jumpered 


16K PROM CARD (Cromemco) 

Bank 0-7 off 
OUT off 
A15 off 
DMA off 
A14 on 

Disable ROM’s 0-7 
Wait Disable 


TUART optional 

1,3-6,8,10 ON 
2,7,9 OFF 

BYTESAVER optional 

A15—Hi A14-LO Al3-Hi A0-BF 
Wait N.C. 

Protect - Off when programming 
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TERMINAL FORMAT 


The 6850 serial communications ports are configured 
by software upon reset as follows: 

7 Data bits 
1 Stop bit 
Even Parity 

Baud rate is set by switches on the trace memory 
interface card. Recommended speed when used with TRACE 
MEMORY, 19,200 baud. 
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INTERRUPT HANDLING 


If RAM resides at interrupt vector locations FFF8-FFFF, 

LNBUG will always point IRQ's and NMI's at it's own pro¬ 
grams upon cool or cold reset. HIRQ (FFF8 and 9 ) is 
then used for the user IRQ vector. If ROM resides at 
FFF8-FFFF, LNBUG will give the user the option to have 
Colleen vectors point at LNBUG. If the option is selected, 
Colleen vector VIMIRQ (216) will point at LNBUG's IRQ rou¬ 
tine and USIRQL (C288) will point at the user IRQ routine. 
Also, thereafter, anytime single step is selected, LNBUG 
will use NMI vectors at WBLKI (222) . If option is not 
selected, vectors for Colleen will be untouched and "ROMFLF" 
will be reset. "ROMFLG" controls options in setting single 
step vectors and in selection either HIRQ or USIRQ for IRQ 
vectors after going through the LNBUG IRQ routine. 

CAUTIONS : 

If interrupts are to occur while LNBUG is running, no in¬ 
terrupt routine should use zero page locations FC-FF as 
this will crash LNBUG. 
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